package Q17_02_Shuffle;
import CtCILibrary.AssortedMethods;
public class Question {
/* Random number between lower and higher, inclusive */
public static int rand(int lower, int higher) {
return lower + (int)(Math.random() * (higher - lower + 1));
}
public static int[] shuffleArrayRecursively(int[] cards, int i) {
if (i == 0) {
return cards;
}
/* shuffle elements 0 through index - 1 */
shuffleArrayRecursively(cards, i - 1);
int k = rand(0, i);
/* Swap element k and index */
int temp = cards[k];
cards[k] = cards[i];
cards[i] = temp;
/* Return shuffled array */
return cards;
}
public static void shuffleArrayIteratively(int[] cards) {
for (int i = 0; i < cards.length; i++) {
int k = rand(0, i);
int temp = cards[k];
cards[k] = cards[i];
cards[i] = temp;
}
}
public static void main(String[] args) {
int[] cards = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(AssortedMethods.arrayToString(cards));
shuffleArrayIteratively(cards);
System.out.println(AssortedMethods.arrayToString(cards));
}
}